import Vue from 'vue'
import App from './App.vue'
import router from './router'
import './plugins/element.js'
// 导入全局样式
import './assets/css/global.css'
// 导入字体图标
import './assets/fonts/iconfont.css'

import TreeTable from 'vue-table-with-tree-grid'

// 导入富文本编辑器
import VueQuillEditor from 'vue-quill-editor'
// 导入富文本编辑器样式
import 'quill/dist/quill.core.css'
import 'quill/dist/quill.snow.css'
import 'quill/dist/quill.bubble.css'

// 导入Nprogress
import Nprogress from 'nprogress'
import 'nprogress/nprogress.css'



import axios from 'axios'
// 配置请求的根路径
axios.defaults.baseURL = 'http://127.0.0.1:8888/api/private/v1/';

// 在request拦截器中展示进度条
// 通过axios请求拦截器添加token,保证拥有获取数据的权限
axios.interceptors.request.use(config => {
    // console.log(config);
    Nprogress.start();
    config.headers.Authorization = window.sessionStorage.getItem('token');
    // 在最后必须return config
    return config;
});

// 在response拦截器中隐藏进度条
axios.interceptors.response.use(config => {
    Nprogress.done();
    return config;
})


Vue.prototype.$http = axios;

Vue.config.productionTip = false;

Vue.component('tree-table', TreeTable);
// 将富文本编辑器注册为全局可用的组件
Vue.use(VueQuillEditor);

Vue.filter('dateFormat', function(originVal) {
    const dt = new Date(originVal);

    const y = dt.getFullYear();
    const m = (dt.getMonth() + 1 + '').padStart(2, '0');
    const d = (dt.getDate() + '').padStart(2, '0');

    const hh = (dt.getHours() + '').padStart(2, '0');
    const mm = (dt.getMinutes() + '').padStart(2, '0');
    const ss = (dt.getSeconds() + '').padStart(2, '0');

    return `${y}-${m}-${d} ${hh}:${mm}:${ss}`;
})

new Vue({
    router,
    render: h => h(App)
}).$mount('#app')